<template>
    <div class="platform-convention-container">
        <el-card class="convention-card">
            <template #header>
                <div class="card-header">
                    <el-icon><InfoFilled /></el-icon>
                    <span>平台公约</span>
                    <el-tag type="info" size="small">更新于 2023-11-19</el-tag>
                </div>
            </template>

            <div class="convention-content article-layout">
                <p class="intro-text">请您在开始使用平台之前，认真阅读并充分理解本协议，以共同营造风清气正的网络空间。</p>

                <div class="article-section">
                    <h2 class="section-title">一、信息内容发布规范</h2>
                    <p class="section-content">在您按规定完成真实身份信息认证后，可以发布视频、图片、文字等信息内容，并保证所发布信息内容（无论是否公开）符合法律法规要求。</p>

                    <el-card class="prohibited-items">
                        <template #header>
                            <div class="card-header">
                                <el-icon><WarningFilled /></el-icon>
                                <span>禁止内容</span>
                            </div>
                        </template>
                        <div class="card-body">
                            <ul>
                                <li>危害国家安全、宣扬恐怖主义、泄露国家秘密、侵害英雄烈士、煽动民族仇恨、侮辱诽谤他人，以及包含色情、赌博、暴力等一切法律、行政法规禁止的内容；</li>
                                <li>内容与标题严重不符、炒作绯闻丑闻、不当描述自然灾害、重大事故、煽动人群歧视、地域歧视、宣扬低俗、庸俗、媚俗、诱导未成年人不良嗜好等违反法律法规、公共政策、公序良俗的内容。</li>
                            </ul>
                        </div>
                    </el-card>
                </div>

                <div class="article-section">
                    <h2 class="section-title">二、网络安全保护</h2>
                    <p class="section-content">您不得使用任何插件、外挂、系统或第三方工具对平台的正常运行进行干扰、破坏、修改或施加其他影响；不得进行任何危害平台系统安全的行为，亦不得利用平台从事任何危害计算机网络安全的行为；不得对平台中的信息或内容进行修改、劫持或其他导致用户无法正常使用平台的行为；不得以盗链、爬虫抓取等任何不正当方式盗取或使用平台中的信息或内容。</p>

                    <el-alert
                        title="违规处理"
                        type="warning"
                        description="如果我们有合理理由认为您的行为违反或可能违反上述约定的，或您有其他行为导致平台的信息和内容受到不利影响，或导致平台用户的权益受损的，我们有权进行处理，包括在不事先通知的情况下终止向您提供服务，并依法追究相关方的法律责任。"
                        show-icon
                    ></el-alert>
                </div>

                <div class="article-section">
                    <h2 class="section-title">三、用户个人信息保护</h2>
                    <p class="section-content">当您开启或使用平台时，我们会处理相关信息，除实现平台基本功能、服务所需的信息和根据法律法规要求所必需的信息之外，您可以拒绝我们处理其他信息，但这可能导致我们无法提供对应功能或服务。</p>

                    <el-row class="protection-measures" :gutter="20">
                        <el-col :span="12">
                            <el-card class="measure-card">
                                <el-icon><Shield /></el-icon>
                                <div class="card-content">
                                    <h3>信息安全保障</h3>
                                    <p>我们将依法保护您浏览、修改、删除相关个人信息以及撤回授权的权利</p>
                                </div>
                            </el-card>
                        </el-col>
                        <el-col :span="12">
                            <el-card class="measure-card">
                                <el-icon><Lock /></el-icon>
                                <div class="card-content">
                                    <h3>技术保护措施</h3>
                                    <p>我们将运用加密技术、匿名化处理等安全技术措施保护您的个人信息</p>
                                </div>
                            </el-card>
                        </el-col>
                    </el-row>
                </div>

                <div class="article-section">
                    <h2 class="section-title">四、未成年人保护</h2>
                    <p class="section-content">若您是未满18周岁的未成年人，您应在监护人指导下认真阅读本协议，经您的监护人同意本公约后，方可使用平台。若您未取得监护人的同意，监护人可以通过平台公示渠道通知平台处理相关账号，平台有权对相关账号的功能（包括但不限于浏览、发布信息、互动交流等）进行限制。</p>

                    <el-divider content-position="left">共同责任</el-divider>

                    <el-row :gutter="20">
                        <el-col :span="12">
                            <el-card class="minor-responsibility">
                                <el-icon><Parent /></el-icon>
                                <h3>监护人责任</h3>
                                <p>您亦应履行对未成年人的监护义务，关注未成年人网络安全，引导未成年人健康合理使用网络。</p>
                            </el-card>
                        </el-col>
                        <el-col :span="12">
                            <el-card class="minor-responsibility">
                                <el-icon><Child /></el-icon>
                                <h3>未成年人义务</h3>
                                <p>未成年人应当在其监护人的监督指导下，在合理范围内正确学习使用网络，养成良好上网习惯，避免沉迷虚拟的网络空间。</p>
                            </el-card>
                        </el-col>
                    </el-row>
                </div>

                <div class="article-section">
                    <h2 class="section-title">五、违约处理</h2>
                    <p class="section-content">如果您违反含平台规则在内的本协议约定，我们有权视情况采取相应的处置措施。</p>

                    <el-table :data="penaltyMeasures" stripe class="penalty-table">
                        <el-table-column prop="level" label="违规等级" width="120"></el-table-column>
                        <el-table-column prop="measure" label="处理措施"></el-table-column>
                        <el-table-column prop="consequence" label="可能后果"></el-table-column>
                    </el-table>

                    <el-alert
                        title="法律责任"
                        type="danger"
                        description="对涉嫌违法犯罪的行为，我们将保存有关记录，并有权依法向有关主管部门报告、配合有关主管部门调查。"
                        show-icon
                    ></el-alert>
                </div>
            </div>

            <template #footer>
                <div class="card-footer">
                    <el-checkbox v-model="agreementChecked" class="agreement-checkbox">
                        我已阅读并同意<a href="#" @click.prevent="showAgreement">《平台公约》</a>和<a href="#" @click.prevent="showPrivacyPolicy">《隐私政策》</a>
                    </el-checkbox>
                    <el-button
                        type="primary"
                        :disabled="!agreementChecked"
                        class="confirm-button"
                        @click="confirmAgreement"
                    >
                        同意并继续
                    </el-button>
                </div>
            </template>
        </el-card>
    </div>
</template>

<script setup>
import { ref, reactive } from 'vue'
import { InfoFilled, WarningFilled, Shield, Lock, Parent, Child } from '@element-plus/icons-vue'

// 状态管理
const agreementChecked = ref(false)

// 表格数据
const penaltyMeasures = reactive([
    {
        level: '一般违规',
        measure: '预先警示、拒绝发布、立即停止传输信息、删除内容',
        consequence: '内容删除、无法正常获取账号内资产或其他权益'
    },
    {
        level: '中度违规',
        measure: '短期禁止发布内容或评论、限制账号部分功能',
        consequence: '账号功能受限、内容删除、无法正常获取账号内资产或其他权益'
    },
    {
        level: '严重违规',
        measure: '终止提供服务、永久关闭账号',
        consequence: '账号信息删除、内容删除、无法正常获取账号内资产或其他权益'
    }
])

// 方法
const confirmAgreement = () => {
    if (agreementChecked.value) {
        alert('感谢您同意《平台公约》，您现在可以继续使用平台服务。')
    }
}

const showAgreement = () => {
    alert('显示完整公约内容')
}

const showPrivacyPolicy = () => {
    alert('显示隐私政策内容')
}
</script>

<style scoped>
.platform-convention-container {
    padding: 20px;
    max-width: 1200px;
    margin: 0 auto;
}

.convention-card {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    border-radius: 8px;
}

.card-header {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 18px;
    font-weight: 600;
}

.intro-text {
    margin: 20px 0;
    text-align: center;
    font-size: 16px;
    color: #606266;
}

.article-layout {
    line-height: 1.8;
}

.article-section {
    margin-bottom: 30px;
}

.section-title {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 15px;
    color: #303133;
    border-bottom: 1px solid #ebeef5;
    padding-bottom: 10px;
}

.section-content {
    margin-bottom: 15px;
}

.prohibited-items {
    margin-top: 15px;
}

.prohibited-items ul {
    padding-left: 20px;
    margin: 0;
}

.prohibited-items li {
    margin-bottom: 8px;
}

.protection-measures {
    margin-top: 15px;
}

.measure-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 15px;
    border-radius: 6px;
    background-color: #f9fafc;
}

.measure-card el-icon {
    font-size: 24px;
    color: #409eff;
}

.minor-steps {
    margin-bottom: 20px;
}

.minor-text {
    margin-bottom: 15px;
}

.minor-responsibility {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 15px;
    border-radius: 6px;
    background-color: #f9fafc;
}

.minor-responsibility el-icon {
    font-size: 30px;
    margin-bottom: 10px;
}

.minor-responsibility h3 {
    margin-bottom: 8px;
    font-weight: 500;
}

.penalty-table {
    margin-bottom: 15px;
}

.card-footer {
    display: flex;
    flex-direction: column;
    gap: 15px;
    padding: 20px 0 10px;
    border-top: 1px solid #ebeef5;
}

.agreement-checkbox {
    display: flex;
    align-items: center;
}

.agreement-checkbox a {
    color: #409eff;
    text-decoration: none;
    margin: 0 5px;
}

.agreement-checkbox a:hover {
    text-decoration: underline;
}

.confirm-button {
    align-self: flex-end;
    width: 150px;
}
</style>